G_DEFINE_TYPE(ConstraintEditorWindow, constraint_editor_window, GTK_TYPE_APPLICATION_WINDOW);
static GtkConstraintTarget *
-find_target (GListModel *model,
+find_target (GListModel *model,
GtkConstraintTarget *orig)
{
const char *name;
GtkConstraint *clone;
GtkConstraintTarget *target;
GtkConstraintTarget *source;
+ GtkConstraintAttribute source_attr;
item = g_list_model_get_item (list, i);
constraint = GTK_CONSTRAINT (item);
target = gtk_constraint_get_target (constraint);
source = gtk_constraint_get_source (constraint);
- clone = gtk_constraint_new (find_target (constraint_view_get_model (CONSTRAINT_VIEW (self->view)), target),
+ source_attr = gtk_constraint_get_source_attribute (constraint);
+
+ if (source == NULL && source_attr == GTK_CONSTRAINT_ATTRIBUTE_NONE)
+ clone = gtk_constraint_new_constant (find_target (constraint_view_get_model (CONSTRAINT_VIEW (self->view)), target),
gtk_constraint_get_target_attribute (constraint),
gtk_constraint_get_relation (constraint),
- find_target (constraint_view_get_model (CONSTRAINT_VIEW (self->view)), source),
- gtk_constraint_get_target_attribute (constraint),
- gtk_constraint_get_multiplier (constraint),
gtk_constraint_get_constant (constraint),
gtk_constraint_get_strength (constraint));
+ else
+ clone = gtk_constraint_new (find_target (constraint_view_get_model (CONSTRAINT_VIEW (self->view)), target),
+ gtk_constraint_get_target_attribute (constraint),
+ gtk_constraint_get_relation (constraint),
+ find_target (constraint_view_get_model (CONSTRAINT_VIEW (self->view)), source),
+ source_attr,
+ gtk_constraint_get_multiplier (constraint),
+ gtk_constraint_get_constant (constraint),
+ gtk_constraint_get_strength (constraint));
constraint_view_add_constraint (CONSTRAINT_VIEW (self->view), clone);
{
int i;
+ if (id == NULL)
+ return NULL;
+
if (strcmp ("super", id) == 0)
return NULL;
{
gtk_widget_set_sensitive (editor->source, TRUE);
gtk_widget_set_sensitive (editor->multiplier, TRUE);
+ gtk_editable_set_text (GTK_EDITABLE (editor->multiplier), "1");
}
}
static void
update_button (ConstraintEditor *editor)
{
- if (gtk_combo_box_get_active_id (GTK_COMBO_BOX (editor->target)) != NULL &&
- gtk_combo_box_get_active_id (GTK_COMBO_BOX (editor->source)) != NULL)
+ const char *target = gtk_combo_box_get_active_id (GTK_COMBO_BOX (editor->target));
+ const char *source = gtk_combo_box_get_active_id (GTK_COMBO_BOX (editor->source));
+ const char *source_attr = gtk_combo_box_get_active_id (GTK_COMBO_BOX (editor->source_attr));
+
+ if (target &&
+ (source || (source_attr && get_target_attr (source_attr) == GTK_CONSTRAINT_ATTRIBUTE_NONE)))
gtk_widget_set_sensitive (editor->button, TRUE);
else
gtk_widget_set_sensitive (editor->button, FALSE);